mysql

推荐列表 站点导航

当前位置:首页 > 数据库 > mysql >

深入sql多表差异化联合查询的问题详解

来源:互联网  作者:网络  发布时间:2020-12-07 21:19
本章简略讲述本人在实例开发中遇到的多表查询的问题 其中主要讲述 select A.*,B.*,C.* from A,B,C 和 select A.*,B.*,C.* from 表...
本章简略讲述本人在实例开发中遇到的多表查询的问题 其中主要讲述 select A.*,B.*,C.* from A,B,C 和 select A.*,B.*,C.* from 表A inner join 表B on A.id=B.id inner join 表C on A.code=C.code 的区别   最近遇到一个这样的项目需求——要求页面集合显示三个关联表的信息。 由于实际项目里出现的字段比较多,现在简化说明如下: table A 含有字段 UserName,CardCode,ItamCode table B 含有字段 CardCode,CardName table C 含有字段 ItamCode,ItamName   其中界面要在一个数据集里同时出现UserName,CardName,ItamName 话说虽然学过SQL 内联,外联的问题,但是以前的项目基本出现的都是两个表的关联实现,现在是第一次用到超过两个表的关联实现问题。在百度找了一下资料,才发现原来基本原理是一样的。哈,本人去年才入职,经验不足,大神们,请别见笑哈! 呃,如果读者暂时还不熟悉SQL基本内联,外联的相关知识,请自觉找度娘面壁去哈,笔者在这里不熬述了。长话短说,现在进入正题……   发现要实现上面的功能有两种方法,分别是 select A.UserName,B.CardName,C.ItamName from A,B,C 和 select A.UserName,B.CardName,C.ItamName from 表A inner join 表B on A.CardCode=B.CardCode inner join 表C on A.ItamCode=C.ItamCode (如果字段是差异化的话,可以略写表名)   就上面的语法来说,其实两种实现方法的效果是一样的,但如果真要较真细说优劣的话,还是第二种实现方法比较实用的。 用inner join(全外联)的写法, 不仅可以按照实际需求自由转化left join(左外联)和right join(右外联),而且注明了结合的顺序, 特别是支持了SQL文优化的方便。   还有一个就是说当我某个字段可以为null的时候,第一种查询方法得出的值其实是不完全的。比如说我上面的例子中当table C 的ItanName 并非必填的时候,只能通过左外连接(left join)来实现我们需要的效果。 有兴趣的同学可以自己操作一下,验证下两种方法的不同。

相关热词: 详解

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!

本文地址: https://v30.fanwenzhu.com/sql/mysql/1142.shtml

最新文章
 这些文件如果在configure命 这些文件如果在configure命

时间:2021-01-22

说明在数据库崩溃时内存 说明在数据库崩溃时内存

时间:2021-01-22

破解极验(geetest)验证码 破解极验(geetest)验证码

时间:2021-01-22

今天这种代码阅读方法仍 今天这种代码阅读方法仍

时间:2021-01-22

 count(*) as cnt from sakila.fi count(*) as cnt from sakila.fi

时间:2021-01-22

 可能你注意到系统提示的 可能你注意到系统提示的

时间:2021-01-22

搭建环境与运行 搭建环境与运行

时间:2021-01-22

MySQL主从复制的常见拓扑 MySQL主从复制的常见拓扑

时间:2021-01-22

Copyright © www.juheyunku.com      关于 | 合作 | 声明 | 联系 | 更新 | 地图 | Tags

深入sql多表差异化联合查询的问题详解

2020-12-07 编辑:网络

本章简略讲述本人在实例开发中遇到的多表查询的问题 其中主要讲述 select A.*,B.*,C.* from A,B,C 和 select A.*,B.*,C.* from 表A inner join 表B on A.id=B.id inner join 表C on A.code=C.code 的区别   最近遇到一个这样的项目需求——要求页面集合显示三个关联表的信息。 由于实际项目里出现的字段比较多,现在简化说明如下: table A 含有字段 UserName,CardCode,ItamCode table B 含有字段 CardCode,CardName table C 含有字段 ItamCode,ItamName   其中界面要在一个数据集里同时出现UserName,CardName,ItamName 话说虽然学过SQL 内联,外联的问题,但是以前的项目基本出现的都是两个表的关联实现,现在是第一次用到超过两个表的关联实现问题。在百度找了一下资料,才发现原来基本原理是一样的。哈,本人去年才入职,经验不足,大神们,请别见笑哈! 呃,如果读者暂时还不熟悉SQL基本内联,外联的相关知识,请自觉找度娘面壁去哈,笔者在这里不熬述了。长话短说,现在进入正题……   发现要实现上面的功能有两种方法,分别是 select A.UserName,B.CardName,C.ItamName from A,B,C 和 select A.UserName,B.CardName,C.ItamName from 表A inner join 表B on A.CardCode=B.CardCode inner join 表C on A.ItamCode=C.ItamCode (如果字段是差异化的话,可以略写表名)   就上面的语法来说,其实两种实现方法的效果是一样的,但如果真要较真细说优劣的话,还是第二种实现方法比较实用的。 用inner join(全外联)的写法, 不仅可以按照实际需求自由转化left join(左外联)和right join(右外联),而且注明了结合的顺序, 特别是支持了SQL文优化的方便。   还有一个就是说当我某个字段可以为null的时候,第一种查询方法得出的值其实是不完全的。比如说我上面的例子中当table C 的ItanName 并非必填的时候,只能通过左外连接(left join)来实现我们需要的效果。 有兴趣的同学可以自己操作一下,验证下两种方法的不同。

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供学习参考!
本文地址为 https://v30.fanwenzhu.com/sql/mysql/1142.shtml

相关文章

风云图片

推荐阅读

返回mysql频道首页